home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c09 / StormyInning.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  4.5 KB  |  118 lines

  1. //: StormyInning.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Overridden methods may throw only the 
  50. // exceptions specified in their base-class 
  51. // versions, or exceptions derived from the 
  52. // base-class exceptions.
  53.  
  54. class BaseballException extends Exception {}
  55. class Foul extends BaseballException {}
  56. class Strike extends BaseballException {}
  57.  
  58. abstract class Inning {
  59.   Inning() throws BaseballException {}
  60.   void event () throws BaseballException {
  61.    // Doesn't actually have to throw anything
  62.   }
  63.   abstract void atBat() throws Strike, Foul;
  64.   void walk() {} // Throws nothing
  65. }
  66.  
  67. class StormException extends Exception {}
  68. class RainedOut extends StormException {}
  69. class PopFoul extends Foul {}
  70.  
  71. interface Storm {
  72.   void event() throws RainedOut;
  73.   void rainHard() throws RainedOut;
  74. }
  75.  
  76. public class StormyInning extends Inning 
  77.     implements Storm {
  78.   // OK to add new exceptions for constructors,
  79.   // but you must deal with the base constructor
  80.   // exceptions:
  81.   StormyInning() throws RainedOut, 
  82.     BaseballException {}
  83.   StormyInning(String s) throws Foul, 
  84.     BaseballException {}
  85.   // Regular methods must conform to base class:
  86. //! void walk() throws PopFoul {} //Compile error
  87.   // Interface CANNOT add exceptions to existing
  88.   // methods from the base class:
  89. //! public void event() throws RainedOut {}
  90.   // If the method doesn't already exist in the
  91.   // base class, the exception is OK:
  92.   public void rainHard() throws RainedOut {}
  93.   // You can choose to not throw any exceptions,
  94.   // even if base version does:
  95.   public void event() {}
  96.   // Overridden methods can throw 
  97.   // inherited exceptions:
  98.   void atBat() throws PopFoul {}
  99.   public static void main(String[] args) {
  100.     try {
  101.       StormyInning si = new StormyInning();
  102.       si.atBat();
  103.     } catch(PopFoul e) {
  104.     } catch(RainedOut e) {
  105.     } catch(BaseballException e) {}
  106.     // Strike not thrown in derived version.
  107.     try {
  108.       // What happens if you upcast?
  109.       Inning i = new StormyInning();
  110.       i.atBat();
  111.       // You must catch the exceptions from the
  112.       // base-class version of the method:
  113.     } catch(Strike e) {
  114.     } catch(Foul e) {
  115.     } catch(RainedOut e) {
  116.     } catch(BaseballException e) {}
  117.   }
  118. } ///:~